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METHOD AND APPARATUS 
FOR REDUCING THE VULNERABILITY 
OF LATCHES TO SINGLE EVENT UPSETS 

Origin of the Invention 

The invention described herein was made by an employee of the United States 
Government and may be manufactured and used by or for the Government of the United 
States of America for governmental purposes without the payment of any royalties 
thereon or therefor. 

Field of the Invention 

This invention relates generally to the field of semiconductor electronics. More 
particularly, this invention relates to making semiconductor electronics less vulnerable to 
radiation. Even more particularly, this invention relates to reducing the vulnerability of 
latches to single event upsets. 

Background of the Invention 

When an particle with sufficient energy passes through a semiconductor it creates 
electron-hole pairs along its path. If the electron-hole pairs occur in a sensitive region, 
such as the drains of N-type or P-type FETs, the electron-hole pairs generate a current 
that temporarily changes the voltage at the drain node in an occurrence called a "glitch." 
After a "recovery time," the electrons and holes generated by the passage of the particle 
are absorbed or carried away and the drain voltage returns to normal. 

A glitch can be particularly disruptive to memory cells or latch circuits. Such 
circuits have feedback paths through which a glitch can be reinforced and stabilized 
before the node's recovery time has elapsed causing the node to stabilize in the glitch- 
induced state. Such an event is referred to as a single event upset or "SEU." 

The latch circuit illustrated in Fig. 1 is an example of a circuit that is susceptible 
to an SEU. A Data signal is applied to Data terminal 102, which is coupled to the gates 
of P-type FET 104 and N-type FET 106. These FETs perform a buffer function isolating 
the input Data signal from the loads required to operate the flip flop. If the input Data 
signal is high (as that term is understood by persons of ordinary skill in the art) then FET 
106 turns on pulling node 108 low. If Data is low, FET 104 turns on pulling node 110 

0 

high. 
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The signal GB (gate bar) determines whether the flip flop holds its current state 
(GB high) or tracks the input Data signal (GB low). FET's 1 12, 1 14, 1 16 and 1 18 are 
gating logic that configure the flip flop for storage (holding current state) or tracking, and 
FET's 120, 122, 124 and 126 are a pair of inverters (128 and 130, respectively) that 
accomplish the storage function. 

With GB low, FET's 1 12 and 1 14 are "on", completing the path between the 
buffered Data nodes 108 and 1 10 and the coupling node 126. FET's 1 16 and 1 18 are 
"off, interrupting the feedback path that re-inforces storage. In this condition the state of 
the flip flop tracks the input Data signal until GB goes high again. 

When the GB signal is high, the Q and QB outputs are maintained by a feedback 
loop composed of FETs 1 16 and 118 (which form a transmission gate), inverter 128 and 
inverter 130. 

To illustrate the effect of a glitch on this circuit, suppose that the signal applied to 
the GB terminal is high, the Q output is high and the QB output is low. This means that 
nodes 132, 134, 136 and 138 are low and node 140 is high. Note that nodes 132 and 134 
are the same physical node and that nodes 136 and 138 are the same physical node. If a 
glitch occurs at, for example, node 134 causing it to be driven high, inverter 130 will 
drive node 140 low. The signal at node 140 will be fed back to the input of inverter 128 
which will drive nodes 136 and 138 high. If the feedback occurs before node 130 has a 
chance to recover from the glitch, node 134 will be driven high and an SEU will have 
occurred. 

Glitches can occur in the latch, as discussed above, or they can be generated in 
logic outside the latch and propagate into the latch through a control line, for example, 
and cause an SEU. 

Existing approaches to making circuits SEU-resistant include inserting resistors, 
capacitors or delay elements, such as inverters, in the feedback loop to slow the response 
of the loop to the glitch and thereby absorb it. Other approaches use redundancy and 
cross-coupled elements. 



In general, in one aspect, the invention features a delay circuit comprising a first 
network having an input and an output node, a second network having an input and an 
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output, the input of the second network being coupled to the output node of the first 
network. The first network and the second network are configured such that: a glitch at 
the input to the first network having a length of approximately one-half of a standard 
glitch time or less does not cause the voltage at the output of the second network to cross 
5 a threshold, a glitch at the input to the first network having a length of between 

approximately one-half and two standard glitch times causes the voltage at the output of 
the second network to cross the threshold for less than the length of the glitch, and a 
glitch at the input to the first network having a length of greater than approximately two 
standard glitch times causes the voltage at the output of the second network to cross the 
10 threshold for approximately the time of the glitch. 

Implementations of the invention may include one or more of the following. The 
network may comprise a P-type FET and an N-type FET. The gates of the two FETs may 
kB be coupled together and the drains of the two FETs may be coupled together. The source 



of the P-type FET may be coupled to the power source and the source of the N-type FET 

M 1 5 being coupled to ground. The channel of at least one of the FETs may be non-linear. 

En 

m The channel of the at least one of the FETs may include a jog. The jog may be a right 

I " \ 

'""'^ angle. The second network may be an inverter. The voltage at the output of the second 

0 network may cross the threshold after a delay relative to the arrival of the glitch at the 

fy input to the first network. The delay may be determined by characteristics of the first 



In general, in another aspect, the invention features an SEU-resistant circuit 
comprising a gate having an input and an output and a feedback path from the output of 
the gate to the input of the gate. The feedback path comprises two or more delay 
elements. The gate and the two or more delay elements are configured to absorb a 
25 standard glitch at the input to the gate before it propagates through the feedback path to 
the input of the gate. The delay is spread among the gate and the two or more delay 
elements. 

Implementations of the invention may include one or more of the following. The 
delay may be substantially evenly spread among the gate and the two or more delay 
30 elements. The delay elements may comprise balanced gates. The feedback path may 
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further comprise a driver gate. The delay elements may comprise inverters. The number 
of delay elements may be even. 

In general, in another aspect, the invention features an SEU-resistant circuit 
having a first state and a second state. The SEU-resistant circuit comprises a first flip- 
5 flop having a first state and a second state. The first flip-flop is configured to change 
state upon application of a signal to a first flip-flop signal input. The SEU-resistant 
circuit also comprises a second flip-flop having a first state and a second state equivalent 
to the first state and the second state of the first flip-flop. The second flip-flop is 
configured to change state upon application of a signal to a second flip-flop signal input. 
10 The first flip-flop is coupled to the second flip-flop such that the SEU-resistant circuit 
does not change from its first state to its second state unless the state of the first flip-flop 
agrees with the state of the second flip-flop. The SEU-resistant circuit includes an input 

M to receive a signal to cause the SEU-resistant circuit to change states when the signal 
changes states. The input is coupled to the first flip-flop signal input. The input is 

Q 1 5 coupled to the second flip-flop signal input through a delay circuit. The input is for one 

p of a clock, reset or preset signal. 

^ Implementations of the invention may include one or more of the following. The 

□ delay circuit may be non-inverting. The delay circuit may have a delay greater than the 

maximum expected glitch time. 

I y 

0 20 In general, in another aspect, the invention features a transition NAND gate 

P comprising two or more input nodes, an output node, and a state machine responsive to 

the two or more input nodes. The state machine is in a current state when signals applied 
to the respective input nodes have specified values. The state machine is capable of 
transitioning from a most recent current state to a state that is not a current state. The 
25 output node stores the current state of the state machine. 

Implementations of the invention may include one or more of the following. The 
output node may have parasitic capacitance and the output node may store the current 
state in its parasitic capacitance. The state machine may comprise a supply-side FET for 
each input terminal. The gate of each supply-side FET may be connected to a respective 
30 input terminal. The supply-side FETs may be connected in series. The series-connected 
supply-side FETs may have a supply end and an output end. The state machine may 
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comprise a ground-side FET for each input terminal. The gate of each ground-side FET 
may be connected to a respective input terminal. The ground-side FETs may be 
connected in series. The series-connected ground-side FETs may have a ground end and 
an output end. The output end of the series-connected supply-side FETs may be 
5 connected to the output end of the series connected ground-side FETs to form an output 
terminal. 

The supply-side FETs may be P-type FETs, and the ground-side FETs may be N- 
type FETs. The state machine may be in a first current state when signals connected to 
the input nodes are all high and in a second current state when signals connected to the 
10 input nodes are all low. 

In general, in another aspect, the invention features an SEU-resistant flip-flop 
comprising a Data input, a GB input, and a network responsive to signals applied to the 
,g Data input and the GB input. The network has a Ql output which has the value of the 

^2 signal applied to the Data input when the signal applied to the GB input is low, and a Q2 

sap 

C3 15 output which has the value of the signal applied to the Data input D seconds after the 

fn 

signal applied to the GB input is low. The Ql output of the network is coupled to a Ql 
^ node and the Q2 output of the network is coupled to a Q2 node. The SEU-resistant flip- 

rj flop includes a two-input one-output TAG. The output of the TAG is configured to 

'X change state only if the value of the signal on its first input is the same as the value of the 

ly 

G 20 signal on its second input. The first input of the TAG is coupled to the Ql node. The 
i:^ second input of the TAG is coupled to the Q2 node. The output of the TAG is coupled to 

a QB node. The SEU-resistant flip-flop includes a first slow inverter having its input 
coupled to the QB node and its output coupled to the Ql node, and a second slow inverter 
having its input coupled to the QB node and its output coupled to the Ql node. 
25 Implementations of the invention may include one or more of the following. The 

SEU-resistant flip-flop may fiirther comprise a transmission gate, gated by the value of 
the signal in the GB node, in a signal path between the first slow inverter and the Ql 
node, and a transmission gate, gated by the value of the signal on the GB node, in a signal 
path between the second slow inverter and the Q2 node. The SEU-resistant flip-flop may 
30 further comprise an inverter coupled to the QB node. 
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The TAG may comprise series-connected P-type FETs. The gate of a first P-type 
FET may be coupled to the Ql node. The gate of a second P-type FET may be coupled 
to the Q2 node. The series-connected P-type FETs may have a supply end and a 
connection end. The TAG may comprise two series-connected N-type FETs. The gate of 
5 a first N-type FET may be coupled to the Ql node and the gate of a second N-type FET 
may be coupled to the Q2 node. The series-connected N-type FETs may have a ground 
end and a connection end. The connection end of the series-connected N-type FETs may 
be coupled to the connection end of the series-connected P-type FETs and to the QB 
node. 

10 The P-type FET coupled to the Q2 node may be at the connection end of the 

series-connected P-type FETs. The N-type FET coupled to the Q2 node may be at the 
connection end of the series-connected N-type FETs. 

The network may comprise a first inverter having its input coupled to the GB 
^2 input. The output of the first inverter may be coupled to a G node. A delay G may have 

£3 15 its input coupled to the G node. The output of the delay G may be coupled to a G2 node. 

m 

An inverter may have its input coupled to the G2 node and its output coupled to a GB2 
W node. A first transmission gate may be coupled between the Data input and the Ql node 

Q and gated by the signals on the GB and G nodes, and a second transmission gate may be 

coupled between the Data input and the Q2 node and gated by the signals on the GB2 and 
C3 20 G2 nodes. The delay G may comprise a first delay coupled in series with a second delay. 

a buffer may be coupled between the Data input and the first and second transmission 



gates. 

In general, in another aspect, the invention features a method for reducing the 
vulnerability of a latch to single event upsets. The latch comprises a gate having an input 
25 and an output and a feedback path firom the output to the input of the gate. The method 
comprises inserting a delay into the feedback path, and providing a delay in the gate. 

Implementations of the invention may include one or more of the following. The 
gate may comprise a first FET having a channel and a second FET having a channel. The 
channel of the first FET and the channel of the second FET may be coupled at a node 
30 having a parasitic capacitance. Providing may comprise adjusting the characteristics of 
the channel of the first FET, the characteristics of the channel of the second FET and the 
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parasitic capacitance of the node. Adjusting may comprise increasing the length of the 
channel of the first FET. Increasing may comprise making the channel non-linear. 
Making may comprise inserting a jog into the channel. The jog may be a right angle. 
The output of the gate may be coupled to a threshold device having an input, an output 
5 and a threshold. The output may have a first value when the input is less than the 
threshold and a second value when the input is greater than the threshold. 

The method may further comprise adjusting the time constant and the threshold so 
that a glitch of length LI at the input to the gate would not effect the output of the 
threshold device, a glitch of length L2, Ll< L2 < L3, would cause a pulse of length L4 < 
10 L2 to appear at the output of the threshold device after a delay determined by the time 
constant and the threshold, and a glitch of length L5 > L3 would cause a pulse of length 
approximately L5 to appear at the output of the threshold device after a delay determined 
by the time constant and the threshold. 
CQ Brief Description of the Drawings 

Q 1 5 Fig. 1 is a schematic of a prior art latch. 

^ Fig. 2 is a schematic of an embedded delay and a compact standard delay 

bi according to the present invention. 

l-j Fig. 3 is a representation of a symbol for a compact standard delay. 

Fig. 4 is a chart showing the response of a compact standard delay according to 
Q 20 the present invention to various glitches. 

Figs. 5 A and 5B are a layout for a compact standard delay according to the 
present invention and a key to the layout. 

Fig. 6 is a schematic of a latch incorporating compact standard delays according 
to the present invention. 
25 Fig. 7A is a schematic of a prior art logic gate. 

Fig. 7B is a schematic of a balanced logic gate according to the present invention. 
Figs. 8 and 9 are charts showing the responses of the latch of Fig. 6 to glitches on 
various nodes of the circuit. 

Fig. 10 is a schematic of a latch according to the present invention with 
30 asynchronous inputs. 
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Figs. 1 1 A and 1 IB are a schematic of a flip flop according to the present 
invention. 

Fig. 12 is a chart showing the response of the latch of Fig. 6 to a glitch. 
Fig. 13 is a schematic of a latch according to the present invention. 
Fig. 14 is a chart showing the response of the latch of Fig. 13 to a glitch. 
Fig. 15 is a block diagram of a cross-coupled flip flop according to the present 
invention. 

Fig. 16 is a block diagram of a plurality of systems cross-coupled through a 
voting/control block according to the present invention. 

Fig, 17 is a schematic of a P and N cross-coupled flip flop according to the 
present invention. 

Fig. 18 is a chart of the response of the cross-coupled flip flop of Fig. 17 to a 

glitch. 

Fig. 19 is a chart of the response of the cross-coupled flip flop of Fig. 17 to a 
standard clock pulse. 

Fig. 20 is a schematic of a bias-coupled flip flop according to the present 
invention. 

Fig. 21 is a chart of the response of the bias-coupled flip flop of Fig. 20 to a 

glitch. 

Fig. 22 is a schematic of a three-input transition NAND gate and a representation 
of the symbol for a TAG. 

Fig. 23 is a schematic of a TAG latch according to the present invention. 

Fig. 24 is a chart showing the response of the latch of Fig. 23 to a glitch. 

Fig. 25 is a schematic of a two-input transition NAND gate and a representation 
of the symbol for a TAG. 

Fig. 26 is a schematic of a latch according to the present invention. 

Fig. 27 is a schematic of a TAG glitch-removing circuit according to the present 



invention. 
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Description of the Preferred Embodiments 

An "embedded delay" and a "compact standard delay," both illustrated in Fig. 2, 
provide building blocks for SEU-resistant circuits. An embedded delay 202 comprises a 
P-type FET 204 and an N-type FET 206 coupled at node 208. An input terminal 210 
5 receives signals for the embedded delay 202. The parameters of the embedded delay's 
FETs 204 and 206 may be adjusted to create a desired time constant, which, when 
coupled with the threshold of the following circuit, cause the embedded delay to: 
(1) suppress entirely input pulses shorter than a first length, (2) delay and shorten (or 
filter) input pulses between the first length and a second length and (3) delay without 
10 substantially modifying pulses longer than the second length. The embedded delay 202 
can be designed into a circuit where the characteristics of the following circuit are under 
the designer's control. Where this condition is not met or where the designer desires to 
insert a delay without disrupting the rest of the circuit, an inverter 212 with knovm and 
controllable characteristics can be coupled to the output node 208 of the embedded delay 

£3 1 5 202, to create a compact standard delay 214. A symbol 302 for the compact standard 

tu 

delay is illustrated in Fig. 3. The parameters of the embedded delay's FETs 204 and 206 
and the threshold of the inverter 212 determine the compact standard delay's 214 delay 
tJ and filtering characteristics. 

Jfl The figures show the FET channel dimensions, length (L) and width (W), relative 

^ 20 to lambda, represented by "1" or "8." Lambda is one half the minimum gate length, 

O 

U which means that the minimum gate length will be 2 ^lambda. For some scalable design 

rules, lambda may deviate slightly. The examples described herein are for an HP 0.5: 
(0.5 micron) N-well process with lambda = 0.3 micron, and nominal load fanout of 10, 
giving a worst case propogation delay of 1 ns (nanosecond). It will be understood by 

25 persons of ordinary skill in the art that a conversion into any particular process may 

require scaling in order to achieve the required timing properties. In many cases, such a 
conversion requires little or no adjustment to the lambda-relative dimensions. 

The switching and filtering functions of the embedded delay 214 shown in Fig. 2 
are illustrated in Fig. 4. Curve 402 is a representation of an input signal applied to input 

30 terminal 210 and curve 404 is a representation of the resulting output signal that appears 
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at node 208. Level 406 represents the input switching threshold of inverter 212. The 
input signal 402 includes a 1 ns pulse 408, a 2 ns pulse 410, and a 0.5 ns pulse 412. The 
response of the compact standard delay 202 to the 1 ns pulse 408 is a pulse 414, which 
crosses the threshold 406 tdeiay ns after the input pulse 408 and crosses the threshold again 
5 less than 1 ns later. The output of the inverter 212 will be a delayed and filtered version 
of the input pulse. 

The response of the compact standard delay 214 to the 2 ns pulse is a pulse 416, 
which crosses the threshold 406 tdeiay ns after the input pulse 408 and crosses the 
threshold again approximately 2 ns later. The output of the inverter 212 will be a 
10 delayed, but otherwise not much affected, version of the input pulse. 

The response of the compact standard delay 214 to the 0.5 ns pulse is a pulse 418, 
which never crosses the threshold. The output of the inverter 212 will be unaffected by 

in the input pulse. 

ffi 

Thus, as shown in Fig. 4, the circuit shown in Fig. 2 will filter out glitches of 

C3 1 5 length less than approximately one-half tdeiay? reduce the length of glitches of length less 

m 

than approximately twice tdeiay? and leave generally unaffected input pulses having 

lengths greater than approximately twice tdeiay 
P One way to create the FET characteristics necessary to produce the results shown 

py in Figs. 4 is to increase the length of an FET channel. This can be accomplished without 

^3 20 significantly increasing the footprint of the FET by changing the geometry of the charmel, 
U for example by inserting right angles into the channel 502, as shown in Fig. 5 A. Fig. 5B 

is a legend for the layers shown in Fig. 5A. Two P-type guard bars 504 provide 

protection against latchup and are arranged to be continuous if two like circuits are placed 

side by side. A row end cap 506 is provided to connect the bars adjacent to the end-most 
25 circuit. The circuit also allows polysilicon gates or wires to cross the guard bars, as 

shown at locations 508, provided substrate contact is maintained on both sides of the 

crossing, also shown. 

An SEU-resistant latch which modifies and builds upon the latch illustrated in 

Fig. 1 by incorporating the concept of the embedded delay is illustrated in Fig. 6. The 
30 SEU-resistant latch includes an added portion 602 and a modified portion 604. The 

added portion includes two embedded delays 606 and 608 within the feedback path 
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discussed above in relation to Fig. 1 and a third delay created by the modified portion 
604. The two compact embedded delays 606 and 608 are sized to provide filtering and 
delay functions as described above. 

Further, the channel dimensions of the FETs within portion 604 shown in Fig. 6 
have been modified as compared to the same FETs shown in Fig. 1 to provide additional 
filtering and delay: 



Fig. 1 (prior art) 


Fig. 6 
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The modifications to FETs 618 and 620 cause them to operate as an embedded 
delay. The addition of embedded delays 606 and 608 provide three elements of delay in 
the feedback path which are adjusted as a group to filter out glitches approximately one 
"standard glitch" time in length. A "standard glitch" time is the typical worst case 
radiation induced glitch width for the particular design or logic family. This is 
approximately equal to the worst case gate propagation time, which may be taken to be 
the signal delay for the weakest gate loaded with the maximum allowed load (fan out). If 
a longer delay is used, a radiation-induced glitch occurring within the delay circuit itself 
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will produce a longer glitch time. Therefore, a delay equal to the worst case glitch 
provides the maximum filtering without increasing the worst possible glitch time. 

These performance characteristics are achieved in simulation by iteratively 
tweaking the FET parameters in the three delay elements, understanding that tweaking 
one of the delay elements will effect the preceding delay element, until the circuit is not 
sent into an SEU by a standard glitch. Simulation results indicate that this result is most 
readily achieved by spreading the desired delay roughly evenly among the three delay 
elements and by balancing the rise-time and fall-time delays for each of the delay 
elements. 

Because there are three delay elements having delays equal to approximately a 
standard glitch time, no glitch having a length less than or equal to a standard glitch time 
is able to set a majority of the following nodes in the feedback path, nor its own driving 
node, before being corrected by the driving node. A glitch approximately the length of a 
standard glitch or shorter will be delayed and shortened by each delay element until it is 
finally absorbed before it proceeds all the way around the loop. 

The modifications to FETs 610, 61 1, 614 and 616 ensure that there are at least 
three elements of delay in the path from any input to the complete setting of all nodes. 
These modifications protect against glitches on the clock (GB) input and on the Data 
input. 

The incorporation of three delay elements in the feedback loop in Fig. 6 is 
accomplished by only adding two inverters 606 and 608. The remaining delay is spread 
over pre-existing components by adjusting the physical parameters of those components 
as described above for the embedded delay. In Fig. 6, the delay is spread over three 
components. It will be understood by persons of ordinary skill in the art that the delay 
can be spread over additional components and achieve the same result. It will also be 
understood by persons of ordinary skill in the art that the location of the delay elements is 
not important as long as they are in the feedback loop. For example, embedded delay 608 
could be moved to between the Q node and the input to inverter 612, with appropriate 
adjustments to the delay elements. 

Glitch resistance is assured in circuits such as the circuit illustrated in Fig. 6 by 
adhering to the following design rules: (a) strictly follow the loading rules for the logic 
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family, and simulate any long connections to make sure no non-standard glitches can 
occur, and (b) use rise/fall time balanced logic gates to make sure no standard glitch is 
subsequently spread to a longer width. A conventional 4-input NAND gate is illustrated 
in Fig. 7 A and a balanced version of the same circuit is illustrated in Fig. 7B. The 
5 channel width, W, of each of the N-type FETs 702, 704, 706 and 708 has been increased 
to balance the fall time of the illustrated gate with its rise time. 

Further glitch-resistance may be achieved by using a third design rule: (c) a latch 
should be clocked with a data setup time approximately two standard glitch times longer 
than the minimum required time to change the state of the latch, and a hold time 
10 approximately one standard glitch time longer. The clock dwell time (GB low) should 
also be at least two standard glitch times longer. This allows the latch to recover and 
capture correct data no matter where the glitch occurs in the clocking cycle, on either the 

CD 

^ Data or clock (GB) inputs, or on one of the latch's internal nodes. 

The performance of the circuit illustrated in Fig. 6 was verified using simulations 
0 15 as shown in Figs. 8 and 9. In the first simulation, a glitch lasting about 0.7 ns (that is, the 

cn 

node spent 0.7 nanoseconds above the switching threshold, approximately the worst case 
iy glitch time for this node), as shown by curve 802, was simulated at node QBS. The glitch 

SI 

C3 passes through output nodes Q and QB, producing curves 804 and 806, respectively. 

?y Since Q and QB are not loaded in this example (which is worst case for a glitch on QBS 

E3 20 or QS), the circuits driving those nodes do not attenuate the glitch. In order to complete 

C3 

the feedback loop, however, the glitch must pass through the third delay incorporated in 
FETs 618 and 620, to node 4, producing curve 808, and through embedded delay 606 to 
node QS, by which time it is attenuated below the switching threshold, as shovm in curve 
810. 

25 If a standard glitch about 1 ns long occurs on the input clock (G or GB), as shovm 

by curve 902 in the simulation illustrated in Fig, 9, it is attenuated at node 4 (curve 904) 
and further attenuated at node QS (curve 906). The glitch never appears on node QBS 
(curve 908) and, consequently, does not appear on node Q or at the output of the flip flop. 
As discussed above, the latch shown in Fig. 6 is glitch-resistant for glitches that 

30 appear on node Q. Consequently, "Preset" and "Clear" asynchronous inputs may be 

added to the circuit, as shown in Fig. 10. A PrB (Preset bar) input is coupled to the gates 
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of a*P-type FET 1002 and an N-type FET 1004. When the signal appHed to PrB is low, 
FET 1002 is turned on and the Q node is raised high. FET 1004 decouples drive FET 
1006 from the ground. When the signal applied to CIB (Clear bar) is low, the output of 
inverter 1008 is high which turns on FET 1010 and drives the Q node low. FET 1012 
decouples drive FET 1014 from the Q node. 

The latch illustrated in Figs. 6 and 10 can be used to construct a variety of storage 
devices. Other devices, such as state machines, counters, and single-clock updateable 
registers, require a flip flop to operate correctly. As is understood by persons of ordinary 
skill in the art, a variety of flip flops, including J-K flip flops and D flip flops, can be 
constructed from a latch plus appropriate combinational logic. A D flip flop can be 
constructed from two latches 1 102 and 1 104 with the clock polarity reversed on the 
second latch 1 104, as shown in Figs. 1 1 A and 1 IB. The two latches can be fully 
protected as shown in Figs. 6 and 10, and preset and clear inputs can be added as shown 
in Fig. 10. Since the latch of Fig. 10 is protected against internal glitches on node Q, and 
since a glitch on the preset or clear inputs PrB and CIB would manifest itself as a glitch 
on node Q, then the latch is also protected against glitches on the preset and clear inputs. 

Returning to Fig. 6, it can be seen that the inverter 613 driving the Q output and 
the inverter 612 driving the QB output were kept "strong" (i.e. fast) so that they can drive 
the number of external loads that is standard for the logic family. In this configuration, 
the circuit's glitch tolerance is most challenged when Q and QB are both lightly loaded 
and a glitch occurs on node 4. As shown in Fig. 12, the glitch almost makes the circuit 
around the feedback loop to node 4 to reinforce itself (curve 1 202), leaving only a 1 .2 
volt margin. The Q node (curve 1204) experiences a short excursion from its pre-glitch 
state. 

More delay could be built into compact standard delays 606 or 608. However, 
this just creates a new critical node, that is, the node that is most susceptible to a glitch. 

Another approach, illustrated in Fig. 13, is to introduce additional delay at node Q 
1302 (renamed Qo) by resizing FET 1304 as shown and deriving a new node Q by 
inverting node QB using inverter 1306. FETs 1308 and 1310 connected to node QS have 
been adjusted to accommodate the revised loading. As can be seen in Fig. 14, the revised 
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circuit has a much smaller response to an even larger glitch (curve 1402). The Qo node 
experiences a smaller excursion with the revised circuit (curve 1404). 

Some devices employ two or more flip flops cross-coupled in such a way that 
none of the flip flops can change state unless they all change state, which protects against 
SEUs that occur within one of the flip flops. Such a device employing two cross-coupled 
flip flops 1502 and 1504 is illustrated in Fig. 15, in which, for simplicity only the clock 
signals and cross-coupling signals are shown. Protection against SEUs on the clock or 
asynchronous preset or clear lines that drive all of the flip flops can be added by inserting 
a compact standard delay 1506 on the line to be protected to one of the flip flops 1504. 

There are other systems, such as that illustrated in Fig. 16, in which the outputs of 
a plurality of N identical systems 1602, 1604, and 1606 are presented with the same 
inputs (not shown). The systems 1602, 1604, and 1606 can be latches, flip flops, 
microprocessors or other elements. The outputs of the N identical systems 1602, 1604, 
and 1606, which should be identical, are coupled to a voting/control element 1608 which 
chooses between them, using conventional techniques, to provide an output. 

To prevent SEUs from affecting such a system, a clock generator circuit 1610 is 
provided which provides three clock outputs. The first clock output is an undelayed 
version of the clock input. The second clock output is delayed by compact standard delay 
1612 and the third clock output is the second clock output delayed by another compact 
standard delay 1614. The three clock outputs are then distributed among the N systems 
1602, 1604, and 1606 so that no one clock output feeds a majority of the N systems. The 
clock generator 1610 may be extended to any number of clock outputs by adding 
compact standard delays. 

Another device, illustrated in Fig. 17, uses cross-coupled P- and N-type latches, 
1702 and 1704, respectively. Because of the cross coupling between the latches, a glitch 
originating at a node within one of the latches is tolerated. Without the additions 1706 
shown in Fig. 17, however, the device is vulnerable to glitches on the clock inputs G 
1708 or GB 1710 and is not readily configured to accept a preset or clear signal. 

The additions illustrated in Fig. 17 derive the two clock signals G 1708 and GB2 
1710 from a single clock signal 1712. As long as the clear signal CLB 1714 is high, the 
GB signal 1712 is inverted by NAND gate 1716 to produce clock signal G 1708. The G 
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signal is delayed by compact standard delay 1718 and inverted by inverter 1720 to 
produce clock signal GB2 1710. The compact standard delay 1718 insures that a glitch 
on one of the clock signals will not arrive simultaneously at the two flip flops 1702 and 
1704. 

The effect of a glitch on the clock line can be compared to glitches on the two 
data lines in quick succession. The flip flop is designed to resist such glitches, but not in 
quick succession. In such a case it has not quite recovered from an ambiguous state 
during the arrival of the delayed clock signal to the upper flip flop. Resizing FETs 1 720 
and 1722 to be four times their original size and FET 1724 to be one-quarter its original 
size eliminates the ambiguity before it can cause an upset. 

A clear input 1714 is added by having a low signal on the CIB input 1714 drive 
the output of AND gate 1726 low so that it appears that the Data input to the flip flops 
1728 is low. The low signal on the clear input 1714 also triggers the clocks G 1708 and 
GB 1710 by driving the output of the NAND gate 1716 low. 

Simulation results, illustrated in Fig. 18, show that the Q output 1802 is 
completely non-responsive to a 1 ns glitch 1804 on the CIB signal. When a true clock 
signal 1902 is applied to the CIB input 1712, as shown in Fig. 19, the flip flops change 
state within 2.5 ns as reflected by the signal on the Q output 1904. Thus, the degradation 
in speed in return for SEU-resistance is quite small. 

In still another circuit, illustrated in Fig. 20, the bias-coupled latches 2002 and 
2004 are rendered resistant to clock line glitches by the addition of a compact standard 
delay 2006 on the clock line GB 2008. A separate delay on the data line 2010 is not 
necessary because the flip flop latches the data at the end of the clock pulse (the rising 
edge of the signal on the clock line GB 2008). By delaying the clock to one portion of 
the flip flops, the data is already sampled at a different time and no further delay is 
necessary. The bias-coupled latches 2002 and 2004 could have clear and/or preset inputs 
added as shown in Fig. 9. Fig. 21 illustrates the response of the circuit in Fig. 20 to a 
glitch 2102 on the clock line G. The signal 2104 on the GB node is affected and the 
signal 2106 on the QB node is perturbed, but the signal 2108 on the Q output remains 
stable. 
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In a traditional logic gate, CMOS transistors are stacked in series on one side of 
the output and in parallel on the other side, as shown in Fig. 7 A and 7B. This type of 
structure forms the ordinary Boolean functions, which provide a fixed output in response 
to the current state of the inputs, without regard for the current state of the gate. The 
5 circuits described above (delays and inverters and protected latch circuits employing 
them) take advantage of the fact that they store their current states for some period of 
time, principally in node parasitic capacitance. Such circuits can be extended beyond 
inverters and delays, and give rise to a new kind of logic gate. 

A three-input transition NAND gate ("TAG") 2202, illustrated in Fig. 22 and 
10 represented by symbol 2204, has three inputs 2206, 2208, and 2210 and one output 221 1 . 
Each of the inputs 2206, 2208, and 2210 is coupled to a P-type FET, 2212, 2214, and 
2216, respectively, and to an N-type FET, 2218, 2220, and 2222, respectively. The P- 
J'^? type FETs are connected in series as are the N-type FETs. One end of the chain of P-type 

£9 FETs is connected to the supply and the other end is connected to one end of the N-type 

[h 15 FETs at node 2226. The other end of the chain of N-type FETs is connected to ground 
2228. 

iy If the output of TAG 2202 is coupled only to capacitive loads or if the gate is 

f =j followed with a buffer, the TAG 2202 will only transition from one logic state to the 

j: other when all of its inputs have transitioned. That is, TAG 2202 will transition from a 

lU 

C3 20 logic state where its output is high to one where its output is low only when all of the 
J: inputs 2206, 2208 and 2210 to the TAG 2002 have dropped low. Similarly, TAG 2202 

will transition from a logic state where its output is low to one where its output is high' 
only when all of the inputs 2206, 2208 and 2210 to the TAG 2002 are high. 

The TAG accomplishes this by storing its current state on the parasitic 
25 capacitance on node 2226. This stored state will not change until all three inputs 2206, 
2208 and 2210 agree. For example, if the stored state of the TAG is low and inputs 2206 
and 2208 are high but input 2210 is low, then the output node 2226 will be disconnected 
from both the supply (by FETs 2212 and 2214) and ground (by FET 2222) so its parasitic 
capacitance will keep it in the low state. If the input 2210 is raised high, the output node 
30 2226 will be connected to the supply 2224 through the three P-type FETs 2212, 2214 and 
2216 and it will be charged to a high state. Persons of ordinary skill in the art will 
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recognize that a TAG can have any number of inputs and can be arranged in different 
ways to accomplish the same purpose. For example, a 4-input TAG would require an 
additional P-type FET and an additional N-type FET. A TAG that changes state when 
two inputs agree or when one input changes state could be made by placing one of the P- 
type FETs in parallel with the other two and one of the N-type FETs in parallel with the 
other two. Other similar modifications could be made to create a variety of such devices. 

This feature of the variety of TAG illustrated in Fig. 22, that it does not change 
state until all of its inputs are the same, makes it a good candidate for use in making a 
circuit SEU-resistant. The TAG itself must be made SEU-resistant to avoid upsets 
caused by radiation hits at the output node 2226, for example. 

An SEU-resistant circuit incorporating a TAG, illustrated in Fig. 23, includes a 
two-input TAG 2302 and two embedded delays 2304 and 2306. If a glitch occurs in 
either of the delays 2304 or 2306, i.e. on nodes Ql or Q2, the TAG does not allow node 
QB to change state, and QB quickly drives the erroneous inverter back to the correct 
state. 

If radiation strikes the TAG itself, causing a glitch at QB, the delays 2304 and 
2306 are sized to provide a slight delay in propagating the glitch. Before the glitch can 
reach nodes Ql or Q2, the TAG has driven node QB back into the correct state. This 
behavior assumes known, controlled loads at Ql, Q2 and QB, so a buffer 2308 is used to 
derive an output Q 2310. Simulation results, illustrated in Fig. 24, show the results of a 
glitch 2402 on QB. Q, Ql and Q2 are all affected, but within half a nanosecond all nodes 
have recovered to their correct states. 

Due to the small number of transistors in the basic flip flop illustrated in Fig. 23 
(only four, exclusive of the drive circuitry), this circuit may be suitable for use in a small 
memory array, such as for a register file or cache. In such array, each individual cell is 
SEU-resistant, lessening the need for error correcting codes or extra unprotected cells. 
For a small array, the size of the memory cells might be offset by eliminating the extra 
protection circuitry. 

The compact standard delays 2312 and 23 14 are necessary because a signal on the 
inputs to the central pair of transistors 23 16 and 23 1 8 in the TAG have a slight coupling 
to the QB node. This coupling causes weak drive on the slow inverters and a long 
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recovery time. The extra clock circuit delay (2 standard delays) completely absorbs any 
clock glitch. Otherwise, the propagation of the glitch to the second input would catch the 
flip flop in a weakened state and upset it. 

This problem can also be alleviated by observing that a clock glitch will always 
5 strike the Ql node first (because the path to the Ql node does not include the delays) and 
connecting the Ql node to the outer pair of transistors 2320 and 2322 rather than the 
central pair 23 1 6 and 23 1 8. Since the outer pair of transistor 2320 and 2322 is separated 
from the QB node by the inner pair of transistors 2316 and 2318, a glitch on the outer 
pair is less likely to affect the QB node. A glitch in the clock delays 23 12 or 23 14 would 
10 only strike Q2 and there would be no following strike on Ql . 

The TAG could be wired so that one each of the inner pair and outer pair of 
transistors is used for each of the inputs, but then both inputs would be vulnerable. It is 
more advantageous to associate the vulnerability with one input 2502, as shown in 
Fig. 25, and designate the vulnerable input with a designation, such as a small "A," on the 



h 15 symbol 2504. 

JJ: If the simplified bias coupled flip flop shown in Fig. 23 is to be used as a logic 

iy flip flop rather than as a memory cell, the node fights on the Ql and Q2 nodes during 

fn setting of the flip flop should be eliminated, as shown in Fig. 26, by the addition of 

^ transmission gates 2602 and 2604 to the feedback loops. Further, the Ql node is 



O 20 connected to the outer transistor pair of the TAG. Finally, the feedback loops include 
i2 compact standard delays 2606 and 2608, rather than the embedded delays 23 12 and 23 14 
shown in the clock circuit in Fig. 23, and the input clock delay is returned to one compact 
standard delay 2310. This arrangement gives operating characteristics roughly similar to 
the circuits described above and a high margin for a delay-based design. 
25 The TAG can also be used to create a circuit that removes glitches from a signal, 

as illustrated in Fig. 27. This is done by delaying the signal to one of the TAG inputs, so 
that in response to a glitch in the signal the TAG never sees both inputs in the same state 
(the first input has recovered by the time the glitch propagates to the second input), and 
thus the TAG never changes state. For this to be completely effective, the TAG may be 
30 modified so that it, itself, is not vulnerable to glitches. For example, the transistors in the 
TAG 2702 may be increased in size so that it produces a glitch-free signal from one that 
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originally included standard glitches. Alternatively, the capacitance at the TAG's 2702 
output node 2704 could be made large enough to absorb a glitch, either by adjusting the 
parameters of the TAG itself, or by adding an outside capacitor 2706. 
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